package cn.edu.scnu.semart.model.goods;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 商品实体类
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("goods")
public class Goods {

    /**
     * 主键ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    /**
     * 卖家用户ID
     */
    @TableField("user_id")
    private Integer userId;

    /**
     * 用户头像
     */
    @TableField("user_avatar")
    private String userAvatar;

    /**
     * 商品名称
     */
    @TableField("user_name")
    private String userName;

    /**
     * 商品名称
     */
    @TableField("goods_name")
    private String goodsName;

    /**
     * 商品描述
     */
    @TableField("description")
    private String description;

    /**
     * 商品价格
     */
    @TableField("price")
    private BigDecimal price;

    /**
     * 原价
     */
    @TableField("original_price")
    private BigDecimal originalPrice;

    /**
     * 商品库存
     */
    @TableField("stock")
    private Integer stock;

    /**
     * 商品分类ID
     */
    @TableField("category_id")
    private Integer categoryId;

    /**
     * 商品主图
     */
    @TableField("main_image")
    private String mainImage;

    /**
     * 商品图片，JSON格式存储多张图片
     */
    @TableField("images")
    private String images;

    /**
     * 商品状态：0-下架，1-上架，2-缺货，3-待审核，4-审核拒绝
     */
    @TableField("status")
    private Integer status;

    /**
     * 销量
     */
    @TableField("sales")
    private Integer sales;

    /**
     * 点赞数
     */
    @TableField("likes")
    private Integer likes;

    /**
     * 收藏数
     */
    @TableField("favorites")
    private Integer favorites;

    /**
     * 商品标签，JSON格式
     */
    @TableField("tags")
    private String tags;

    /**
     * 审核状态：0-待审核，1-审核通过，2-审核拒绝
     */
    @TableField("audit_status")
    private Integer auditStatus;

    /**
     * 审核人ID
     */
    @TableField("auditor_id")
    private Integer auditorId;

    /**
     * 审核人姓名
     */
    @TableField("auditor_name")
    private String auditorName;

    /**
     * 审核时间
     */
    @TableField("audit_time")
    private LocalDateTime auditTime;

    /**
     * 审核备注
     */
    @TableField("audit_remark")
    private String auditRemark;

    /**
     * 拒绝原因
     */
    @TableField("reject_reason")
    private String rejectReason;

    /**
     * 创建时间
     */
    @TableField(value = "create_time", fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    /**
     * 更新时间
     */
    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;

    /**
     * 逻辑删除标志：0-未删除，1-已删除
     */
    @TableLogic
    @TableField("deleted")
    private Integer deleted;
} 